草庐IT

node.js - Node-http-proxy 动态路由表?

全部标签

ruby - 有没有办法将 Ruby Net::HTTP 请求附加到特定的 IP 地址/网络接口(interface)?

我正在寻找一种使用标准Net::HTTP库为每个GET请求使用不同IP地址的方法。服务器有5个IP地址,并假设某些API在达到每个IP的请求限制时阻止访问。所以,唯一的办法就是使用另一台服务器。我在ruby​​文档中找不到任何关于它的信息。例如,curl允许您将其附加到特定的ip地址(在PHP中):$req=curl_init($url)curl_setopt($req,CURLOPT_INTERFACE,'ip.address.goes.here';$result=curl_exec($req);有什么方法可以用Net::HTTP库来实现吗?作为替代方案-CURB(rubycurl绑

ruby - open-uri 没有将 http 重定向到 https

我正在使用Hpricot和OpenURI来解析网页并从中提取URL。当我收到类似“http:rapidshare.com”的链接时,它不会重定向到https。这是我得到的错误:/home/leonidus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/open-uri.rb:216:in`open_loop':redirectionforbidden:http:.................=>https:...........................我尝试使用异常处理程序OPENURI::HTTPREDIRECT但我又遇到了同样的错

Ruby、Tor 和 Net::HTTP::Proxy

如果这是一个愚蠢的疑问,我提前道歉:我想在我的Ruby代码中使用代理来获取一些网页。我想偷偷摸摸!所以我正在使用Tor。我正在运行Tor,我可以像往常一样使用Net::HTTP.get(uri)。但我不知道如何使用Net::HTTP::Proxy来获取uri。我也无法弄清楚使用Tor将如何帮助使我的抓取匿名。非常感谢任何帮助。请不要只添加linktotheruby-docpageforNet::HTTP::Proxy.如果我明白这一点,我就不会在这里问这个了:-)另一种简单的方法是使用SOCKSify,但在这种情况下,我收到以下错误:/usr/lib/ruby/gems/1.9.2-p

ruby - 如何在 ruby​​ 中动态设置嵌套哈希?

假设我有一个嵌套哈希:h={'one'=>{'two'=>{'three'=>'a'}}}我可以这样改:h['one']['two']['three']='b'如何更改以变量为键的嵌套值?假设我有以下变量:key="one.two.three"要动态访问它,我使用以下内容:key.split('.').inject(h,:[])当然这样设置是行不通的:key.split('.').inject(h,:[])='b'#fails那么如何动态设置嵌套散列的值呢? 最佳答案 Hash#[]=是一个单一的方法。您不能一直执行Hash#[]直

ruby-on-rails - 在 Ruby Net::HTTP.start 中为服务调用设置 read_timeout

我想在我的ruby​​代码中覆盖服务调用的默认超时。我打开连接如下。res=Net::HTTP.start(@@task_url.host,@@task_url.port)do|http|http.get("/tasks/#{task_id}")end我尝试如下设置read_timeout时间,但随后我的代码中出现了NoMethodError异常。res=Net::HTTP.start(@@task_url.host,@@task_url.port)res.read_timeout=10resdo|http|http.get("/tasks/#{task_id}")end建议我应该如何

ruby - 我怎样才能给 Sinatra 一个包罗万象的默认路由?

对于小型开发人员文档应用,我想设置一个Sinatra应用来仅提供HAML文件。在CSS文件和图像的路由之后,我想要一个尝试为您请求的任何路径加载HAML文件的路由。例如:/index加载views/index.haml,如果它存在的话/this/page/might/exist加载views/this/page/might/exist.haml,如果存在的话我将如何指定这条路线? 最佳答案 看起来像这样做:get'/*'doviewname=params[:splat].first#eg"some/path/here"ifFile.

Ruby HTTP 获取参数

如何通过ruby​​发送带参数的HTTPGET请求?我尝试了很多例子,但都失败了。 最佳答案 我知道这篇文章很旧,但是为了那些由谷歌带到这里的人,有一种更简单的方法可以以URL安全的方式对您的参数进行编码。我不确定为什么我没有在其他地方看到这个,因为该方法记录在Net::HTTP页面上。我已经看到Arsen7描述的方法也是其他几个问题的公认答案。在Net::HTTP中提到文档是URI.encode_www_form(params):#Letssaywehaveapathandparamsthatlooklikethis:path="

ruby - 如何在ruby中动态定义实例方法?

我想通过父类的类方法动态创建子类的实例方法。classFoodefself.add_fizz_method&body#???(Thisisline3)endendclassBarnilclassBaradd_fizz_methoddop"iliketurtles"endendBar.new.fizz#=>"iliketurtles"在第3行写什么? 最佳答案 像这样使用define_method:classFoodefself.add_fizz_method&blockdefine_method'fizz',&blockendend

ruby - 如何使用 Net::HTTP 只读取正文的 x 个字节?

在读取网页正文时,Ruby的Net::HTTP方法似乎是全有或全无。例如,我如何读取正文的前100个字节?如果请求的文件不可用,我正在尝试从内容服务器读取内容服务器,该内容服务器会在响应正文中返回一条简短的错误消息。我需要阅读足够多的正文以确定文件是否存在。文件很大,所以我不想让整个body只是为了检查文件是否可用。 最佳答案 这是一个旧线程,但根据我的研究,如何在Ruby中通过HTTP只读取文件的一部分的问题仍然是一个大部分没有答案的问题。这是我通过猴子修补Net::HTTP得到的一个解决方案:require'net/http'#

ruby - 在 Ruby 中,使用 "net/http",我们必须加入 url 并自己使用 "?"进行查询?

在下面的代码中,我们必须使用?字符加入url.path和url.query吗?有更优雅的方法吗?我必须使用net/http,因为在某些情况下我也想在用户代理的header中放置一个字符串。require'net/http'url_string='http://www.time.gov/timezone.cgi?Pacific/d/-8'url=URI.parse(url_string)response=Net::HTTP.start(url.host,url.port)do|http|http.get(url.path+'?'+url.query)endputsresponse.bod